//给定一个单链表，把所有的奇数节点和偶数节点分别排在一起。请注意，这里的奇数节点和偶数节点指的是节点编号的奇偶性，而不是节点的值的奇偶性。
//
// 请尝试使用原地算法完成。你的算法的空间复杂度应为 O(1)，时间复杂度应为 O(nodes)，nodes 为节点总数。
//
// 示例 1:
//
// 输入: 1->2->3->4->5->NULL
//输出: 1->3->5->2->4->NULL
//
//
// 示例 2:
//
// 输入: 2->1->3->5->6->4->7->NULL
//输出: 2->3->6->7->1->5->4->NULL
//
// 说明:
//
//
// 应当保持奇数节点和偶数节点的相对顺序。
// 链表的第一个节点视为奇数节点，第二个节点视为偶数节点，以此类推。
//
// Related Topics 链表 👍 478 👎 0

package leetcode.editor.cn;

import com.sicheng.algorithm.node.ListNode;

@SuppressWarnings("all")
//Java：奇偶链表
public class OddEvenLinkedList {
    public static void main(String[] args) {
        Solution solution = new OddEvenLinkedList().new Solution();
        // TO TEST
        ListNode head = ListNode.initList(new int[]{1, 2, 3, 4});
        solution.oddEvenList(head);

    }
//leetcode submit region begin(Prohibit modification and deletion)

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     * int val;
     * ListNode next;
     * ListNode() {}
     * ListNode(int val) { this.val = val; }
     * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
     * }
     */
    class Solution {
        public ListNode oddEvenList(ListNode head) {

            if (head == null)
                return null;

            // 奇数指针
            ListNode oddTemp = head;
            // 偶数指针
            ListNode evenTemp = oddTemp.next;
            ListNode evenHead = evenTemp;
            // 思路 交换法 当前指针之后的元素如果大于1，
            // 交换 当前指针后2个结点的顺序
            // 移动当前指针 -> current.next.next

            while (evenTemp != null && evenTemp.next != null) {
                oddTemp.next = evenTemp.next;
                oddTemp = oddTemp.next;
                evenTemp.next = oddTemp.next;
                evenTemp = evenTemp.next;
            }
            oddTemp.next = evenHead;
            return head;


        }
    }
//leetcode submit region end(Prohibit modification and deletion)


}
